﻿
-- ================================================
-- Remarks: 
-- ================================================
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

IF EXISTS (SELECT * FROM sysobjects WHERE type = 'P' AND name = 'Ivy_UserProfile_Update')
	BEGIN
		DROP  Procedure  Ivy_UserProfile_Update
	END

GO
CREATE PROCEDURE [Ivy_UserProfile_Update]
-- =============================================
-- Author:		<Ali Balcı>
-- Create date: <24/03/2011>
-- Description:	<Ivy_UserProfile_Update>
-- =============================================
-- Add the parameters for the stored procedure here
	(
				@UserKey int,
				@UserFullName varchar(150),
				@UserSex char(1),
				@UserDateOfBirth datetime,
				@UserAlternateEmailID varchar(150),
				@UserContactNumber varchar(50),
				@UserContactAddress varchar(500),

				
				@Sys_ModifiedByID varchar(50) = NULL,
				@Sys_DeleteType int = 0,
				@Sys_IsDeleted bit = false,
				@Sys_OrganizationID int=-1,
				@Sys_InitialPrimaryKeys varchar(max) = NULL,
				@Sys_WorkstationName varchar(50) = NULL,
				@ConcurrencyTimeStamp datetime = NULL,
				
				@Sys_DateOfModification datetime OUTPUT
	)
AS
begin
	-- SET NOCOUNT ON added to prevent extra result sets from
	-- interfering with SELECT statements.
	SET NOCOUNT OFF;
	
	-- ConcurrencyTimeStamp is mandatory and it needs to check if any other user has changed the reord or not	
	IF @ConcurrencyTimeStamp = Null
	BEGIN
		RAISERROR('Missing @ConcurrencyTimeStamp', 11,1);
	END
	DECLARE @CurrentModificationDate datetime;
	SET @CurrentModificationDate = (SELECT [Sys_DateOfModification] FROM [UserProfile] WHERE [UserKey] = @UserKey);
	If @ConcurrencyTimeStamp != @CurrentModificationDate
	BEGIN
		RAISERROR('Record is Changed by another process', 11,1);
	END

	IF @Sys_WorkstationName = 'Default'	
	BEGIN
		SET @Sys_WorkstationName = (SELECT @@SERVERNAME);
	END
	SET @Sys_DateOfModification = GETDATE();
	
	UPDATE	[UserProfile]
	SET 
			[UserKey] = @UserKey, 
			[UserFullName] = @UserFullName, 
			[UserSex] = @UserSex,
			[UserDateOfBirth] = @UserDateOfBirth, 
			[UserAlternateEmailID] = @UserAlternateEmailID,
			[UserContactNumber] = @UserContactNumber, 
			[UserContactAddress] = @UserContactAddress,
			[Sys_DateOfModification] = @Sys_DateOfModification, 
			[Sys_ModifiedByID] = @Sys_ModifiedByID, 
			[Sys_DeleteType] = @Sys_DeleteType, 
			[Sys_IsDeleted] = @Sys_IsDeleted, 
			[Sys_OrganizationID] = @Sys_OrganizationID, 
			[Sys_InitialPrimaryKeys] = @Sys_InitialPrimaryKeys, 
			[Sys_WorkstationName] = @Sys_WorkstationName 
	WHERE 
		(
			[UserKey] = @UserKey
		)
END
GO
